.hot {
    width: 100%;
    height: 100%;
    cursor: pointer;
}

.hot-title {
    color: var(--text-color);
    font-size: 40px;
    user-select: text;
}

.hot-desc {
    color: var(--text-color);
    font-size: 14px;
    font-weight: bold;
    margin: 20px 0;
    user-select: text;
}

.hot-img {
    position: relative;
    width: 100%;
    height: 100%;
    max-height: 500px;

}

.hot-img::before {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background-color: rgba(255, 255, 255, .5);
    opacity: 0;
}

.hot-img img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

@media screen and (min-width: 1024px) {
    .hot:hover .hot-title {
        color: var(--main-color);
    }

    .hot:hover .hot-img::before {
        opacity: 1;
    }
}